# Interrupciones en Modo Protegido Organizacion del Computador II

#### Javier Pimás

Departamento de Computacion Facultad de Ciencias Exactas y Naturales Universidad de Buenos Aires

Primer Cuatrimestre 2014

#### Refresco de Memoria

- Soporta 256 tipos de interrupciones
- Se utiliza una tabla denominada IDT
- La IDT almacena descriptores de interrupcion
- El registro IDTR almacena la direccion de la IDT

#### IDTR and IDT



Figure 5-1. Relationship of the IDTR and IDT

# Gate Descriptors



DPL Descriptor Privilege Level
Offset to procedure entry point
P Segment Present flag
Selector Segment Selector for destination code segment
D Size of gate: 1 = 32 bits; 0 = 16 bits
Reserved

Figure 5-2. IDT Gate Descriptors

# Interrupt Procedure Call



Figure 5-3. Interrupt Procedure Call

# Interrupt Task Switch



Figure 5-5. Interrupt Task Switch

# Tipos de Interrupciones

- Fault: Excepcion que puede corregirse permitiendo al programa retomar la ejecucion de esa instruccion sin perder continuidad. El procesador guarda en la pila la direccion de la instruccion que produjo la falla.
- Traps: Excepcion producida inmediatamente a continuacion de una instruccion de trap. Algunas permiten al procesador retomar la ejecucion sin perder continuidad. Otras no. El procesador guarda en la pila la direccion de la instruccion a ejecutarse luego de la instruccion trapeada.
- Aborts: Excepcion que no siempre puede determinar la instruccion que la causo, ni permite recuperar la ejecucion de la tarea que la causo. Reporta errores severos de hardware o inconsistencias en tablas del sistema.

# Interrupt Table

Table 5-1. Protected-Mode Exceptions and Interrupts

| Vector<br>No. | Mne-<br>monic | Description                                   | Туре           | Error<br>Code | Source                                                              |
|---------------|---------------|-----------------------------------------------|----------------|---------------|---------------------------------------------------------------------|
| 0             | #DE           | Divide Error                                  | Fault          | No            | DIV and IDIV instructions.                                          |
| 1             | #DB           | RESERVED                                      | Fault/<br>Trap | No            | For Intel use only.                                                 |
| 2             | -             | NMI Interrupt                                 | Interrupt      | No            | Nonmaskable external interrupt.                                     |
| 3             | #BP           | Breakpoint                                    | Тгар           | No            | INT 3 instruction.                                                  |
| 4             | #OF           | Overflow                                      | Trap           | No            | INTO instruction.                                                   |
| 5             | #BR           | BOUND Range Exceeded                          | Fault          | No            | BOUND instruction.                                                  |
| 6             | #UD           | Invalid Opcode (Undefined Opcode)             | Fault          | No            | UD2 instruction or reserved opcode. <sup>1</sup>                    |
| 7             | #NM           | Device Not Available (No<br>Math Coprocessor) | Fault          | No            | Floating-point or WAIT/FWAIT instruction.                           |
| 8             | #DF           | Double Fault                                  | Abort          | Yes<br>(zero) | Any instruction that can generate an exception, an NMI, or an INTR. |
| 9             |               | Coprocessor Segment<br>Overrun (reserved)     | Fault          | No            | Floating-point instruction. <sup>2</sup>                            |
| 10            | #TS           | Invalid TSS                                   | Fault          | Yes           | Task switch or TSS access.                                          |
| 11            | #NP           | Segment Not Present                           | Fault          | Yes           | Loading segment registers or accessing system segments.             |

# Interrupt Table

| 12 | #SS | Stack-Segment Fault                          | Fault | Yes           | Stack operations and SS register loads.           |
|----|-----|----------------------------------------------|-------|---------------|---------------------------------------------------|
| 13 | #GP | General Protection                           | Fault | Yes           | Any memory reference and other protection checks. |
| 14 | #PF | Page Fault                                   | Fault | Yes           | Any memory reference.                             |
| 15 | -   | (Intel reserved. Do not use.)                |       | No            |                                                   |
| 16 | #MF | x87 FPU Floating-Point<br>Error (Math Fault) | Fault | No            | x87 FPU floating-point or WAIT/FWAIT instruction. |
| 17 | #AC | Alignment Check                              | Fault | Yes<br>(Zero) | Any data reference in memory. <sup>3</sup>        |

Table 5-1. Protected-Mode Exceptions and Interrupts (Contd.)

| 18         | #MC | Machine Check                              | Abort     | No | Error codes (if any) and source are model dependent. <sup>4</sup> |
|------------|-----|--------------------------------------------|-----------|----|-------------------------------------------------------------------|
| 19         | #XM | SIMD Floating-Point<br>Exception           | Fault     | No | SSE/SSE2/SSE3 floating-point instructions <sup>5</sup>            |
| 20-31      | -   | Intel reserved. Do not use.                |           |    |                                                                   |
| 32-<br>255 | -   | User Defined (Non-<br>reserved) Interrupts | Interrupt |    | External interrupt or INT <i>n</i> instruction.                   |

#### NOTES:

- 1. The UD2 instruction was introduced in the Pentium Pro processor.
- 2. Processors after the Intel386 processor do not generate this exception.
- 3. This exception was introduced in the Intel486 processor.
- This exception was introduced in the Pentium processor and enhanced in the P6 family processors.
- 5. This exception was introduced in the Pentium III processor.

#### Stack



Figure 5-4. Stack Usage on Transfers to Interrupt and Exception-Handling Routines

#### Error Code



Figure 5-6. Error Code

- **EXT**: (External Event) Se setea para indicar que la excepcion ha sido causada por un evento externo al procesador
- **IDT**: (Descriptor Location) Cuando esta seteado indica que el campo Segment Selector Index se refiere a un descriptor de puerta en la IDT. Cuando esta en cero indica que dicho campo se refiere a un descriptor en la GDT o en la LDT de la tarea actual.
- TI: (GDT/LDT) Tiene significado cuando el bit anterior esta en cero. Indica a que tabla de descriptores corresponde el selector del campo Indice. (GDT=0, LDT=1)

## Ayudas

- 1 idt.h: Descripcion de las estructuras.
- ② idt.c: Estructura de la IDT con cada una de sus entradas
- isr.h: Descripcion de las funciones handlers
- isr.asm: Codigo de los handlers
  - IDT\_ENTRY(numero): Permite declarar una entrada en la IDT, para la utilizar el handler de nombre \_isrX
  - void inicializar\_idt(): Funcion llamada desde el kernel para inicializar las entradas en la idt

Struct de descriptor de IDT

unsigned short attr;

unsigned short offset\_16\_31;

#### **IDT**

typedef struct str\_idt\_descriptor {
 unsigned short idt\_length;
 unsigned int idt\_addr;
} \_\_attribute\_\_((\_\_packed\_\_)) idt\_descriptor;

• Struct de una entrada de la IDT
 typedef struct str\_idt\_entry\_fld {
 unsigned short offset\_0\_15;
 unsigned short segsel;

} \_\_attribute\_\_((\_\_packed\_\_, aligned (8))) idt\_entry;

Gracias!!!

Preguntas?

Ahora a darle átomos al TP3!

Ref: Intel Software developer's manual (vol. 3) capítulo 6, interrupciones (tan sólo 10 pags)